* • 

1 1) A system for recognizing a particular pattern formed by a plurality of bytes in a 

2 stream of bytes, said system operating in a series of states, and said system 

3 including: 

4 a plurality of look up tables, one for each of said plurality of bytes, each look 

5 up table having a section associated with each state/ ^ 

6 a first index table which has index data associated with each state, the index 

7 data associated with each state comprising a plurality of index bits/and 

8 a next state table which has a data word associated with each state, each 
(4 9 data word having data that specifies the next state and/or a special 
| io flag, 

Q li said system performing the following steps in each particular state of a series of 

in 

£ 12 states^* 

jljj 13 a) interrogating a particular section of each lookup table utilizing the value of 

14 the associated bytes to determine the value of a series of bits, said 

fy is particular section of each lookup table being determined by the 

rj 16 particular state^ 

P 17 b) generating a pointer from a combination of the value of the series of bits 

is determined by said lookup tables and the bits in current state location 

19 in said first index table, said pointer specifying the address of a 

20 particular data word in said next state table, j 

21 c) reading the particular data word specified by the pointer generated in step 

22 "b" and based on the contents of said data word proceeding to the 

23 next state specified by said data word and/or performing special 

24 operations in response to said fla^and 

25 d) repeating steps "a" , "b" and "c" until an end of operation is indicated by 

26 said flag. 

27 

28 2) The system recited in table 1 wherein all of said plurality of bytes are used to 

29 interrogate said look up tables in parallel. 

30 
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3) The system recited in claim 1 wherein those bytes that cause the same transition 
are grouped into classes whereby multiple bytes can be represented by a single 
class, each class having a single entry in any particular single section of said table. 

4) The system recited in claim 1 wherein at each state, each look up table 
generates a series of bits, the particular series of bits generated being dependent 
upon the particular value of the associated of byte. 

5) The system recited in claim 4 wherein said look up tables generate a variable 
number of bits depending upon the particular state of operation. 

6) The system recited in claim 3 wherein the bits generated by any look up table 
depends upon the number of character classes of the associated byte. 

7) The system recited in claim 4 wherein the bits generated by said plurality of look 
up tables are concatenated together and then concatenated with said value from 
said first index table. 

8) The system recited in claim 4 wherein the bits generated by said plurality of look 
up tables and said value from said first index table are combined to form the 
address of a location is said next state table. 

9) The system recited in claim 1 wherein said data stream comprises a stream of 
bytes that form a data packet, said particular operation is the recognition of a 
particular pattern of bytes in a data packet and wherein a signal is given when said 
pattern is recognized. 

10) The system recited in claim 9 wherein when a particular pattern of bytes is 
recognized, said operation continues to another state to find another occurrence of 
said pattern of byes in said packet. 
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1 

2 11) The method of recognizing a particular pattern formed by a plurality of bytes in 

3 stream of bytes, said method operating in a series of states, and utilizing: 

4 a plurality of look up tables, one for each of said plurality of bytes, each look 

5 up table having a section associated with each stat^j 

6 a first index table for storing a plurality of index bits associated with each 

7 particular state^and 

8 a next state table for storing data words, each of which indicates the next 

9 state and/or a special operation flag, 

10 said method including the following steps in each particular state in a series of 

11 state^ 

12 a) interrogating a particular section of each lookup table utilizing the value of 

13 the associated byte to determine the value of a series of bits, said 

14 particular section of each look up table being based on the particular 

15 stat<^' 

16 b) generating a pointer which specifies the address of a data word in said 

17 next state table from a combination of the selected values from the 
is lookup tables and a value from the first index table associated with 

19 the particular state^£ 

20 c) reading the particular data work specified in step "b" and based on the 

21 contents of said data word proceeding to the next state and/or 

22 performing operations indicated by a flag in said data work^and 

23 d) repeating steps "a" , "b" and "c" until a flag in said next state table 

24 indicates an end of the operation. 

25' 

26 12) The method recited in claim 1 1 wherein all of said plurality of bytes are matched 

27 with data in said look up tables in parallel. 

28 

29 13) The method recited in claim 1 1 wherein those bytes that cause the same 

30 transition are grouped into classes whereby multiple bytes can be represented by a 
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i single class, each class having a single entry in a section of said table. 

2 

3 14) The method recited in claim 1 1 wherein at each state, each look up table 

4 generates a series of bits, the particular series of bits generated being dependent 

5 upon the particular value of the associated byte. 

6 

7 15) The method recited in claim 14 wherein said tables generate a variable number 

8 of bits depending upon the particular state of operation. 

10 16) The method recited in claim 1 1 wherein the bits generated by any look up table 

O ii depends upon the class of the associated byte. 

lj 1 

£ 12 

i 

: 13 17) The method recited in claim 14 wherein the bits generated by said plurality of 

14 look up tables are concatenated together and then concatenated with said value 

fjj is from said first index table. 

U 1 6 

u 

Q 17 18) The method recited in claim 1 1 wherein said classes are a compressed 
18 representation of the alphabet used in said state machine. 

19 

20 19 The system recited in claim 1 wherein the series of bits generated by each look 

21 up table has a number of bits that can vary from state to state. 

22 

23 20) The method recited in claim 1 1 wherein the series of bits generated by each 

24 look up table has a number of bits that can vary from state to state. 

25 

26 21) The system recited in claim 1 wherein said system includes four look up tables. 

27 

28 22) The system recited in claim 1 wherein each of said tables has 256 entries for 

29 each state. 

30 
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23) The system recited in claim 1 wherein said system includes a number of look 
up table which is a multiple of four. 

24) The system recited in claim 1 wherein each of said look up tables has a 
number of entries equal to the values in the alphabet used by said bytes. 

25 An integrated circuit for recognizing a plurality of characters in parallel, said 
integrated circuit operating in series of states, and said integrated circuit including ^ 

a plurality of look up tables, one for each of said characters, each look up 
table having a section associated with each state/ ^ 

an index table for storing a plurality of index bits for each state^and 



a next state table for storing data words, each of which indicates the next 
state of said state machine, 
said integrated circuit performing the following steps in a plurality of particular 



a) interrogating the section of said look up table associated with said 

particular state and generating a series of bits based on the value of 



b) generating a pointer which specifies the address of a data word in said 
next state table from a combination of the selected values from the 



c) reading the particular data word specified in step "b" and proceeding to the 



d) repeating steps "a" , "b" and "c" until said operation ends. 

26) The integrated circuit recited in claim 25 wherein the number of bits generated 
by said look up tables and the number of bits in the value from said current state 
table vary by state, and the total number of bits is the same in all states. 





the associated character/' 



lookup tables and a value from said first index tabl^ 



state specified by said data word/and 
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1 27) The integrated circuit recited in claim 25 wherein there are four look up tables 

2 and four characters are evaluated in parallel. 

3 

4 28) A method for evaluating in parallel a plurality of characters in a stream of bytes, 

5 said method operating in a series of states and utilizing a set of alphabet 

6 lookup tables, one lookup table for each of said plurality of characters, each 

7 look up table having a section associated with each of said states, and a 
h= 8 next state table, said method comprising: 

Js| 9 a) selecting an alphabet lookup table from said set of alphabet tables, as a 

io function of a current state and byte position within said set of bytes, 

ill 

ry li and obtaining a class code from said selected alphabet table 

\e A 12 corresponding to the character represented by said byte; 

iiJ 

JJ 13 b) selecting a value from said next state table as a function of the current 

^ 14 state, and generating an indication of the next state from said class 

is codes of said set of bytes and from said value from said next state 

16 tably^ <*s)& 

17 c) repeating steps "a" and "b" until said state machine arrives at acceptance 

18 state or until entering a failure state. 

19 
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29) A system for recognizing a particular pattern formed by a number of bytes in a 
stream of bytes, said number being at least one, said system operating in a 
series of states, and said system including \ 

a look up table for each byte in said number of bytes, each look up table 

having a section associated with each stately 
a first index table which has index data associated with each state, the index 



and 

a next state table which has a data word associated with each state, each 
data word having data that specifies the next state and/or a special 



said system performing the following steps in each particular state of a series of 



a) interrogating a particular section of each lookup table utilizing the value of 

each of said bytes to determine the value of a series of bits, said 
particular section of each lookup table being determined by the 
particular state/^ 

b) generating a pointer from a combination of the series of bits generated by 

the lookup tables and bits in the current state location in said first 
index table, said pointer specifying the address of a particular data 
word in said next state 

c) reading the particular data word specified by the pointer generated in step 

"b" and based on the contents of said data word proceeding to the 
next state specified by said data word and/or performing special 
operations in response to said flag^and 

d) repeating steps "a" , "b" and "c" until an end of operation is indicated by 

said flag. 



data associated with each state comprising a plurality of index 




.flag, 



states/ I 
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30) The system recited in claim 1 wherein said system includes a mask with one bit 

for each of said plurality of bytes in a data packet, and said steps including 
an initial step of selecting bits for processing utilizing said mask. 

31) The method recited in claim 10 wherein said method utilizes a mask with one 

bit for each of said plurality of bytes in a data packet, and said steps 
including an initial step of selecting bits for processing utilizing said mask. 
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